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(57) Abstract: Disclosed is a programmable logic circuit control apparatus and method, and a program, which facilitate smooth 
execution of multiple processes in complicated procedures. A module address memory section (3) stores data indicating the address 
of a module to be read by a circuit control section (4) or a condition for a branch process and a jump distance for each page. The 
circuit control section (4) reads data stored on the topmost page in the module address memory section (3). According to the data, 
the circuit control section (4) performs reading of a module, reconfiguration of a programmable logic circuit (1) and reading of data 
of the next page, or jumps. Every time a new page is read, the circuit control section (4) performs processes according to data stored 
on that page, thereby sequentially reconfiguring the programmable logic circuit (1). 
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DESCRIPllON 

PROGRAMMABLE LOGIC CIRCUIT CONTROL APPARATUS, 
PROGRAMMABLE LOGIC CIRCUIT CONTROLMETHOD AND PROGRAM 

5 

Technical Field 

The present invention relates to a progranmiable logic circuit control apparatus, a 
programmable logic circuit control method and a program. 

Backgroimd Art 

10 In fields where ASICs (Application Specific Integrated Circuits) are used, there is a 

demand of flexible adaptation to changes in specifications during development of an ASIC, 
and shortening the development stage of a product To meet the demand, progranamable 
logic circuits, such as a field programmable gate array (FPGA) (e.g., XC series by XILBSfX 
in U.S. A.) and a programmable logic device (PLD), are widely used, A programmable 

1 5 logic circuit can freely change the logic configuration of an intemal logic circuit according 
to circuit information loaded. 

Recenfly, logic configurations demanded of ASICs are becoming complex, and the 
scales of ASICs are becoming larger. Accordingly, there is a case where construction of an 
ASIC is constructed by using programmable logic circuits, therefore, several programmable 

2 0 logic circuits to several scores of programmable logic circuits are used in some case. 

Paying attention to the fact that not aU the parts of a large-scale logic circuit are 
always operating, several schemes of designing an ASIC smaller are proposed. The 
schemes reconfigure a programmable logic circuit in such a way that the same 
programmable logic circuit achieves different functions at different times (see Unexamined 

2 5 Japanese Patent AppUcation KOKAI Publications Nos. 2001-202236, 2003-198362 and 
2003-029969, for example). The schemes can make the scale of an ASIC smaller by 
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reconfiguring a programmable logic circuit 

However, complex ASICs do not just execute processes one after another. ASICs 
are generally expected to execute a process in complicated procedures including conditional 
branching, returning firom a branched step and loops. The aforementioned schemes of 
5 reconfiguring a progranomable logic circuit face a difficulty in smoothly executing multiple 
processes in such complicated procedures and suffer a long overhead. 

Disclosure of Invention 
Accordingly, it is an object of the present invention to provide a programmable 
logic circuit control apparatus, a programmable logic circuit control method and a program, 
1 0 which facilitate smooth execution of multiple processes in complicated procedures. 

To achieve the object, a programmable logic circuit control apparatus according to 
the first aspect of the invention comprises: 

a controller (4) which supplies a control signal to an extemal programmable logic 
circuit (1) having a function of changing a logic configuration in accordance with a 
1 5 supplied control signal; 

a module storage memory (2) which stores a plurality of modules each comprised 
of data defining a logic configuration of the programmable logic circuit (1); and 

a module usage order designation memory (3) which has a plurality of ordered 
memory positions, each of the memory positions storing data for designating an address of 
20 a memory position of the module storage memory (2) in which a module to be executed is 
stored or storing data for designating an address of another memory position of this module 
usage order designation memory (3), 

wherein the controller (4) acquires data stored at a memory position in the module 
usage order designation memory (3), 
2 5 determines which of an address of the memory position storing the module and an 

address of the another memory position is designated by the acquired data. 
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when having determined that the acquired data designates an address of the module, 
acquires the module stored in a memory position indicated by the address from the module 
storage memory (2), generates a control signal which controls the programmable logic 
circuit (1) to take a logic configuration defined by the module and suppUes the generated 
5 control signal to the programmable logic circuit (1), and 

when having determined that the acquired data designates another memory position, 
acquires data stored at the another memory position from the module usage order 
designation memory (3). 

The programmable logic circuit control apparatus easily and smoothly executes a 
1 0 process of changing the logic configuration of a programmable logic circuit even when the 
process involves complicated procedures including branch processes. 

When data stored at a memory position in the module usage order designation 
memory (3) designates another memory position in the module usage order designation 
memory (3), the data may include condition definition data designating a condition to start 
15 a process of acquiring data stored at the another memory position. 

The controller (4) may determine whether a condition designated by the condition 
definition data included in the acquired data is fulfilled or not when having determined that 
the acquired data designates another memory position, 

may acquire data stored at the another memory position of the module usage order 
2 0 designation memory (3) when having determined that the condition is fulfilled, and 
may abort acquisition of data at the another memory position when having 
determined that the condition is not fulfilled. 

The logic circuit control apparatus with the structure easily and smoothly executes a 
process of changing the logic configuration of a programmable logic circuit even when the 
2 5 process involves complicated procedures including conditional branching. 

The condition designated by the condition definition data may relate to a value 
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given by a signal which is generated at a predetermined node of the programmable logic 
circuit (1). 

In this case, when having determined that data stored at a memory position in the 
module usage order designation memory (3) designates another memory position, the 
5 controller (4) may acquire the signal ftom the node of the progranamable logic circuit (1). 
Based on the value given by the acquired signal, the controller (4) may determine whether 
that condition which is designated by the condition definition data included in the data 
acquired from the module usage order designation memory (3) is fulfilled or not 

Data stored at a memory position in the module usage order designation memory 
1 0 (3) may include identification data for identifying which one of an address of the memory 
position storing a module and an address of another memory position is designated by the 
stored data. 

In this case, based on the identification data included in the data acquired fi:om the 
module usage order designation memory (3), the controller (4) may determine which of an 
1 5 address of the memory position storing the module and an address of the another memory 
position is designated. 

A programmable logic circuit control apparatus according to the second aspect of 
the invention acquires a module comprised of data defining a logic configuration of an 
external programmable logic circuit (1) having a function of changing a logic configuration 
20 in accordance with a supplied control signal from a module storage memory (2) which 
stores a plurality of modules, generates a control signal which controls the programmable 
logic circuit (1) to take a logic configuration defined by the acquired module and supplies 
generated control signal to the programmable logic circuit (1), and comprises: 

means which acquires data stored at a memory position in an extemal module usage 
2 5 order designation memory (3) which has a plxarality of ordered memory positions, each of 
the memory position storing data for designating an address of a memory position of the 
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module storage memory (2) in which a module to be executed is stored or storing data for 
designating an address of another memory position of this module usage order designation 
memory (3), from the module usage order designation memory (3); 

means which determines which of an address of the memory position storing the 
5 module and an address of the another memory position is designated by acquired data; 

means which, when it is determined that the acquired data designates an address of 
the module, acquires the module stored in a memory position indicated by the address from 
the module storage memory (2), and changes the logic configuration of the programmable 
logic circuit (1) so that ttie programmable logic circuit (1) takes a logic configuration 
1 0 defined by the module; and 

means which, when it is determined fliat the acquired data designates another 
memory position, acquires data stored at the another memory position from the module 
usage order designation memory (3). 

This programmable logic circuit control apparatus also easily and smoothly 
1 5 executes a process of changing the logic configuration of a programmable logic circuit even 
when the process involves complicated procedures including branch processes. 

A programmable logic circuit control method according to the third aspect of the 
invention supplies a control signal to an extemal programmable logic circuit (1) having a 
frinction of changing a logic configuration in accordance with the supplied control signal, 
2 0 and comprises the steps of: 

storing a plurality of modules each comprised of data defining a logic configuration 
of the programmable logic circuit (1); 

storing data for designating an address of a memory position storing a module or an 
address of another memory position at each of a plurality of ordered memory positions; 
2 5 acquiring data stored at each of the memory positions; 

determining which of an address of the memory position storing the module and an 
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address of the another memory position is designated by the acquired data; 

when it is determined that the acquired data designates an address of a memory 
position storing a module, acquiring the module stored in tihe memory position indicated by 
the address, generating a control signal which controls the programmable logic circuit (1) to 
5 take a logic configuration defined by the module and supplying the control signal to the 
programmable logic circuit (1); and 

when it is determined that the acquired data designates an address of another 
memory position, acquiring data stored at the another memory position. 

The programmable logic circuit control method easily and smoothly executes a 
1 0 process of changing the logic configuration of a programmable logic circuit even when the 
process involves complicated procedures including branch processes. 

A programmable logic circuit control method according to the fourth aspect of the 
invention acquires a module comprised of data defining a logic configuration of an external 
programmable logic circuit (1) having a function of changing a logic configuration in 
1 5 accordance with a supplied control signal ficbm a module storage memory (2) which stores a 
plurality of modules, generates a control signal which controls the programmable logic 
circuit (1) to take a logic configuration defined by the acquired module and supplies the 
control signal to the programmable logic circuit (1), and comprises the steps of: 

acquiring data stored at a memory position in an external module usage order 
2 0 designation memory (3) which has a plurality of ordered memory positions, each of the 
memory positions storing data for designating an address of a memory position of the 
module storage memory (2) in which a module to be executed is stored or storing data for 
designating an address of another memory position of this module usage order designation 
memory (3); 

2 5 determining which of an address of the memory position storing the module and an 

address of the another memory position is designated by the acquired data; 
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when it is detemained that the acquired data designates an address of a memory 
position storing a module, acquiring the module stored in the memory position indicated by 
the address from the module storage memory (2), and changing the logic configuration of 
the programmable logic circuit (1) so that the progranaanable logic circuit (1) takes a logic 
5 configuration defined by the module; and 

when it is determined that the acquired data designates another memory position, 
acquiring data stored at the another memory position fi"om the module usage order 
designation memory (3). 

This programmable logic circuit control method also easily and smoothly executes 
10 a process of changing the logic configuration of a programmable logic circuit even when 
the process involves complicated procedures including branch processes. 

A program according to the fifth aspect of the invention allows a computer to 
function as: 

a controller (4) which supplies a control signal to an external programmable logic 
1 5 circuit (1) having a function of changing a logic configuration in accordance with the 
supplied control signal; 

a module storage memory (2) which stores a plurality of modules each comprised 
of data defining a logic configuration of the progra333mable logic circuit (1); and 

a module usage order designation memory (3) which has a plurality of ordered 
2 0 memory positions, each of the memory positions storing data for designating an address of 
a memory position of the module storage memory (2) in which a module to be executed is 
stored or storing data for designating an address of another memory position of the module 
usage order designation memory (3), . 

wherein the controller (4) acquires data stored at a memory position in the module 
2 5 usage order designation memory (3), 

determines which of an address of the memory position storing the module and an 
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address of the another memory position is designated by the acquired data, 

when having determined that the acquired data designates an address of a module, 
acquires the module stored in a memory position indicated by the address from the module 
storage memory (2), generates a control signal which controls the programmable logic 
5 circuit (1) to take a logic configuration defined by the module and supplies the generated 
control signal to the programmable logic circuit (1), and 

when having determined that the acquired data designates another memory position, 
acquires data stored at the anoflier memory position from the module usage order 
designation memory (3). 
10 A computer which executes the program easily and smoothly executes a process of 

changing the logic configuration of a programmable logic circuit even when the process 
involves complicated procedures including branch processes. 

A program according to the sixth aspect of the invention allows a computer to 
frmction as a programmable logic circuit control apparatus that acquires a module 
1 5 comprised of data defining a logic configuration of an external programmable logic drcuit 
(1) having a function of changing a logic configuration in accordance with a supplied 
control signal from a module storage memory (2) which stores a plurality of modules, 
generates a control signal which controls the programmable logic circuit (1) to take a logic 
configuration defined by the acquired module and supplies generated control signal to the 
2 0 progranamable logic circuit (1), and further allows the computer to perform the fimctions of: 
acquiring data stored at a memory position in an external module usage order 
designation memory (3) which has a plurality of ordered memory positions, each of the 
memory positions storing data for designating an address of a memory position of the 
module storage memory (2) in which a module to be executed is stored or storing data for 
2 5 another memory position of this module usage order designation memory (3); 

determining which of an address of the memory position storing the module and an 
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address of the another memory position is designated by acquired data; 

when it is determined that the acquired data designates an address of a module, 
acquiring the module stored in a memory position indicated by the address from the module 
storage memory (2), and changing the logic configuration of the programmable logic circuit 
5 (1) so that the programmable logic circuit (1) takes a logic configuration defined by the 
module; and 

when it is determined that the acquired data designates another memory position, 
acquiring data stored at the another memory position from the module usage order 
designation memory (3). 
10 A computer which executes the program also easily and smoothly executes a 

process of changing the logic configuration of a programmable logic circuit even when the 
process involves complicated procedures including branch processes. 

As apparent from the above, the present invention realizes a programmable logic 
circuit control apparatus and method, and a program, which facilitate smooth execution of 
1 5 multiple processes in complicated procedures. 

Brief Description of Drawings 
These objects and other objects and advantages of the present invention will 
become more apparent upon reading of tiie following detailed description and the 
accompan3dng drawings in which: 
2 0 FIG 1 is a diagram illustrating the structure of a programmable logic circuit control 

apparatus according to one embodiment of the present invention; 

FIG 2 is an exemplary diagram showing the configuration of a programmable logic 

circuit; 

FIG 3 is a diagram showing the configuration of an input logic circuit BIBC; 
2 5 FIG 4 is a diagram showing the configuration of a logic circuit BFBC; 

FIG 5 is a diagram showing the configuration of a logic circuit BQBC; 
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FIG 6 is a diagram showing the configuration of an output logic circuit BOBC; 

FIG 7 A is a diagrana showing the structure of a matrix switch, and FIG 7B is a 
diagram showing the structure of switches which constitutes the matrix switch; 

FIG 8 is an exemplary diagram showing the data structure of data stored in a 
5 module address memory section; and 

FIG 9 is a flowchart illustrating the flow of a process which is executed by a circuit 
control section. 

Best Mode for Carrying Out the Invention 
A preferred embodiment of the preset invention, as adapted to a programmable 
1 0 logic circuit control apparatus, will be described below with reference to the accompanying 
drawings. 

FIG 1 illustrates the structure of the programmable logic circuit control apparatus. 
The programmable logic circuit control apparatus includes a programmable logic circuit 1, 
a module memory section 2, a module address memory section 3, and a circuit control 

1 5 section 4. The programmable logic circuit 1, the module memory section 2 and the module 
address memory section 3 are connected to the circuit control section 4. 

The programmable logic circuit 1 is comprised of a configurable logic block (CLB), 
which is used to construct, for example, a field programmable gate array (FPGA) produced 
by XILBSIX in U.S A., a matrix switch, a wiring material and so forth. The programmable 

2 0 logic circuit 1 changes (reconfigures) its logic configuration (ie., the correlation between 
signals to be input to the programmable logic circuit 1 and signals to be output therefrom) 
under the control of the circuit control section 4. As exemplified in FIG 2, for example, the 
programmable logic circuit 1 includes input logic circuits BIBC, logic circuits BFBC, logic 
circuits BQBC, output logic circuits BOBC, a matrix switche BLSW, wires LVIX) to LVL4 

2 5 and wires LHLO to LHL2. 

Each of the wires LVLO to LVL4 and the wires LHLO to LHL2 consists of 63 signal 
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lines. The input logic circuits BIBC, the logic circuits BFBC, the logic circuits BQBC and 
the output logic circuits BOBC are connected to the wires LVLO to LVL4 via buses. The 
wires LVLO to LVL4 and the wires LHLO to LHL2 are connected to one another or 
disconnected from one another by the matrix switch BLSW. The matrix switch BLSW 
5 realizes variable interconnection. 

Each of the input logic circuit BDSC, the logic circuit BFBC, the logic circuit 
BQBC and the output logic circuit BOBC is constituted by, for example, a TTL (Transistor- 
Transistor Logic) circuit or a CMOS (Complementary Metal-Oxide Semiconductor) logic 
circuit or so. 

1 0 Each input logic circuit BIBC supplies a signal input to the programmable logic 

circuit 1 to the wire LVLO in a mode according to the control of the circuit control section 4. 
Each input logic circuit BIBC is comprised of, for example, an output select circuit OSELl 
as shown in FIG 3. 

The output select circuit OSELl is connected to the wire LVLO via buses loA(l) to 
1 5 IoA(63) of 63 bits. The output select circuit OSELl supplies a 4-bit signal input to the 
programmable logic circuit 1 to the signal lines constituting the wire LVLO. Based on the 
value of a 24-bit control signal Configl supplied from the circuit control section 4 or so, the 
output select circuit OSELl decides to which signal line in the wire LVLO the signal is to be 
supplied. The output select circuit OSELl then sends the signal to the decided signal line. 
2 0 The output select circuit OSELl can decide not to send the signal to any of the signal lines 
of the wire LVLO. 

Each logic circuit BFBC performs a logical operation on a signal supplied from the 
wire LVLO or LVLl under the control of the circuit control section 4. The logic circuit 
BFBC sends the acquired signal to the wire LVLl or LVL2. Each logic circuit BFBC 
2 5 includes, for example, an input select circuit ISELl, a basic ftinction cell FBC and an 
output select circuit OSEL2 as shown in FIG 4. 
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The input select circuit ISELl is connected to the wire LVLO or LV LI via buses 
EA.(1) to IiA(63) of 63 bits. The input select circuit ISELl acquires a 6-bit signal among 
signals supplied from the wire LVLO or LVLl to which the input select circuit ISELl is 
connected. The input select circuit ISELl sends the acquired signal to the basic function 
5 cell FBC. Based on the value of a 36-bit control signal ConfigFi supplied from the circuit 
control section 4 or so, the input select circuit ISELl decides from which six signal lines in 
the 63 signal lines of the wire LVLO or LVLl the signal is to be acquired. The iuput select 
circuit ISELl acquires the signal from the decided signal lines. The input select circuit 
ISELl then sends the acquired signal to the basic ftinction cell FBC. The input select 

1 0 circuit ISELl can decide not to acquire a signal from any of the signal lines of the wire 
LVLO or LVLL In this case, the input select circuit ISELl sends a signal representing a 
logic value "0" to the basic ftinction cell FBC. 

The basic function cell FBC includes, for example, a select circuit SEL and a latch 
circuit L as shown in FIG 4. 

1 5 Based on the value of the 6-bit signal supplied from the input select circuit ISELl , 

the basic fimction cell FBC selects a total of two bits, one bit from the first to 64-th bits of a 
130-bit control signal ConfigFf supplied from the circuit control section 4 or so, and one bit 
from the 65-th to 128-th bits of the control signal ConfigFf. The basic fimction cell FBC 
sends the 2-bit signal (signal XY) to the output select circuit OSEL2. Based on the values 

20 of the 129-th and 130-fh bits of the control signal ConfigFf, the basic fimction cell FBC 
decides wheth^ or not to latch the signal XY. The basic fimction cell FBC then sends a 
signal EN indicating the result of the decision to the latch circuit L. 

Based on the signal EN, the latch circuit discriminates whether or not it is decided 
to latch the signal XY. When it is decided to latch the signal XY, the latch circuit L holds 

25 the value of the signal XY. Then, the latch circuit L sends a 2-bit signal having the held 
value to the output select circuit OSEL2 as a signal QY. When it is not decided to latch the 
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signal XY, on the other hand, the latch circuit L sends a 2-bit signal having a value currently 
held (i-e., the old value of the signal XY) to the output select circuit OSEL2 as the signal 
QY. At the tune of latching the signal XY, the individual sections of the progrannnable 
logic circuit 1 perform latching in synchronism with a clock signal. The programmable 
5 logic circuit 1 may acquire the clock signal extemally. Alternatively, the programmable 
logic circuit 1 may have a circuit to generate the clock signal. 

The output select circuit OSEL2 is connected to the wire LVLl or LVL2 via buses 
loB(l) to IoB(63) of 63 bits. The output select ckcuit OSEL2 supplies the signal XY and 
the signal QY, a total of four bits, supplied fix>m the basic function cell FBC to the signal 

1 0 lines constituting the wire LVLl or LVL2. The output select circuit OSEL2 decides to 

which signal line in the wire LVLl or LVI^ the 4-bit signal is to be supplied, based on the 
value of a 24-bit control signal ConfigFo supplied from the circuit control section 4 or so. 
The output select circuit OSEL2 then sends the 4-bit signal to the decided signal line. The 
output select circuit OSEL2 can decide not to send the signal to any of the signal lines of 

15 the wire LVLl or LVL2. 

Each logic circuit BQBC holds a signal supplied from the wire LVL2 or LVL3 in a 
mode according to the control of the circuit control section 4. The logic circuit BQBC 
gives the signal to the logic circuit BFBC in the programmable logic circuit 1 after 
reconfigure to a next logic configuration via the wire LVLO or LVLl. Each logic circuit 

2 0 BQBC includes, for example, an input select circuit ISEL2, a function cell QBC and an 
output select circuit OSEL3 as shown in FIG 5. 

The input select circuit ISEL2 is connected to the wire LVL2 or LVL3 via buses 
EB(1) to IiB(63) of 63 bits. The input select circuit ISEL2 acquires a 4-bit signal among 
signals supplied from the wire LVL2 or LVL3 to which the input select circuit ISEL2 is 

2 5 connected. The iuput select circuit ISEL2 sends the acquired signal to the function cell 
QBC. Based on the value of a 24-bit control signal ConfigQi supplied from the circuit 
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control section 4 or so, the input select circuit ISEL2 decides from which four signal lines 
in the 63 signal lines of the wure LVL2 or LVL3 the signal is to be acquired. The input 
select circuit ISEL2 acquires signals of a total of four bits from the decided signal lines, and 
sends the acquired signal to the function cell QBC. The input select circuit ISEL2 can . 
5 decide not to acquire a signal from any of the signal lines of the wire LVL2 or LVL3. In 
this case, the input select circuit ISEI^ sends a signal representing a logic value "0" to the 
function cell QBC. 

The function cell QBC is comprised of a latch circuit or so. The function cell QBC 
holds the value of a 4-bit signal supplied from the input select circuit ISEL2. The function 
1 0 cell QBC sends a signal having the held value to flxe output select circuit OSEL3 as a signal 
QY2. 

The output select circuit OSEL3 is connected to the wire LVL3 or LV L4 via buses 
loC(l) to IoC(63) of 63 bits. The output select circuit OSEL3 supplies the 4-bit signal QY2 
supplied from the frinction cell QBC to the signal lines constituting the wire LVL3 or LVL4. 

1 5 The output select circuit OSEL3 decides to which signal line in the wire LVL3 or LVL4 the 
signal QY2 is to be supplied, based on the value of a 24~bit control signal ConfigQo 
supplied from the circuit control section 4 or so. The output select circuit OSEL3 then 
sends the signal to the decided signal line. The output select circuit OSEL3 can decide not 
to send the signal to any of the signal lines of the wire LVL3 or LVL4. 

2 0 Each output logic circuit BOBC outputs a signal supplied from the wire LVL4 in a 

mode according to the control of the circuit control section 4. Each output logic circuit 
BOBC includes, for example, an input select circuit ISEL3 and a function cell OBC as 
shown in FIG 6. 

The input select circuit ISEL3 is connected to the wire LVL4 via buses liC(l) to 
2 5 IiC(63) of 63 bits. The input select circuit ISEL3 acquires a 4-bit signal among signals 
supplied from the wire LVL4 to which the input select circuit ISEL3 is connected. The 
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input select circuit ISEL3 sends the acquired signal to the function cell OBC. Based on the 
value of a 24-bit control signal ConfigO supplied from the circuit control section 4 or so, 
the input select circuit ISEL3 decides from which four signal lines in the 63 signal lines of 
the wire LVL4 the signal is to be acquired. The input select circuit ISEL3 acquires signals 
5 of a total of foxir bits from the decided signal lines, and sends the acquired signal to the 
function cell OBC. The input select circuit ISEL3 can decide not to acquire a signal from 
any of the signal lines of the wire LVL4. In this case, the input select circuit ISEL3 sends a 
signal representing a logic value "0" to the function cell OBC. 

The fimction cell OBC is comprised of a latch circuit or so. The function cell OBC 

1 0 holds the value of a 4-bit signal supplied from the input select circuit ISEL3 or passes this 
signal. Whether to hold or pass the signal is decided based on the 25-th to 28-th bits in the 
control signal ConfigO. The function cell OBC sends out a signal having the held value or 
the signal that has passed as an output signal (signal Y) of the programmable logic circuit 1. 
The matrix switch BLSW has a capability of electrically connecting or 

1 5 disconnecting the wires LVLO to LVL4 and the wires LHLO to LHL2 to one another or 
from one another. The matrix switch BLSW electrically connects or disconnects the wires 
LVLO to LVL4 from one another, electrically connects or disconnects flie wires LHLO to 
LHL2 from one another, or electrically connects or disconnects the wires LVLO to LVL4 to 
or from the wires LHLO to LHL2 in accordance with a value of a control signal (hereinafter 

20 the control signal will be referred to as control signal ConfigL) supplied from the circuit 
control section 4, etc. 

As shown in FIG 7A, for example, the matrix switch BLSW, which connects or 
disconnects wires LVLm (m being an integer from 0 to 4) to or from wires LHLn (n being 
an integer from 0 to 2), is comprised of 3969 switches Q which connect or disconnect wires 

2 5 LVLm-j (j being an integer from 1 to 63) to or from wires LHLn-k (k being an integer from 
1 to 63). Each switch Q is comprised of a switching element, such as field effect transistor 
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(FET), for example, as shown in FIG 7B. In the example illustrated in FIG 7, a FET Ql 
connects or disconnects two signal lines LVLm-j A and LVLm-jB constituting the wire 
LVLm-j to or ficom each other. A FET Q2 connects or disconnects two signal lines LHLn- 
kA and LHLn-kB constituting wires LHLn-k to or from each other. A FET Q3 connects or 
5 disconnects the signal line LVLm-j A and the signal line LHLa-kA to or from each other. A 
FET Q4 connects or disconnects the signal line LVLm-j A and the signal line LHLn-kB to 
or from each other. A FET Q5 connects or disconnects the signal line LVLm-jB and the 
signal line LHLn-kA to or fix)m each other. A FET Q6 connects or disconnects the signal 
line LVLm-jB and the signal line LHLn-kB to or from each other. When the switches Q 

1 0 has the structure as shown in FIG 7B, a control signal ConfigL should be applied to, for 
example, the gate of each of the FETs constituting the switches Q. 

The wires LVLO to LVL4 are connected to the input logic circuits BBBC, the logic 
circuits BFBC, the logic circuits BQBC and the output logic circuits BOBC. The wires 
LHLO to LHL2 are connected to the matrix switch BLSW. The wires LHLO to LHL2 are 

1 5 not directly connected to the input logic circuits BIBC, the logic circuits BFBC, and the 
logic circuits BQBC (though the wires LHLO to LHL2 may be connected to those circuits 
via the matrix switch BLSW). 

As the matrix switch BLSW has the above-described capability, the wiring in the 
programmable logic circuit 1 changes based on the control signal ConfigL supplied to the 

2 0 matrix switch BLSW from the circuit control section 4 or so. The input logic circuits BIBC, 
the logic circuits BFBC, and the logic circuits BQBC are connected to one another via the 
wires LVLO to LVL4 and the wires LHLO to LHL2 under the control of the circuit control 
section 4 or so. As a result, the programmable logic circuit I as a whole becomes a logic 
circuit which has a capability of executing predetermined processes that are determined by 

25 the contents of modules to be discussed later. 

Each of the module memory section 2 and the module address memory section 3 is 
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comprised of a memory, such as a RAM (Random Access Memory). Each of the modxde 
memory section 2 and the module address memory section 3 reads out data (to be 
discussed) stored therein in response to an access made by the circuit control section 4. The 
module memory section 2 and the module address memory section 3 sends the read data to 
5 the circuit control section 4, 

The module memory section 2 stores data (hereinafter called "module") which 
defines the logic configuration of the programmable logic circuit 1 as exemplified in FIG 1. 
A single module indicates the whole of or a part of the logic configuration that one 
progranunable logic circuit 1 can express at a time. A module may indicate all the logic 

1 0 configurations of the input logic circuits BIBC, the logic circuits BFBC, the logic circuits 
BQBC and the output logic circuits BOBC as shown in FIG 2. Altematively, a module 
may be for reconfiguration of a part of the logic curcuit BFBC or a part of the logic circuit 
BQBC, without changing the logic configurations of the other logic circuits, as per the 
apparatus as disclosed in, for example. Unexamined Japanese Patent Application KOKAI 

1 5 Publication No. 2003-198362 or Unexamined Japanese Patent Application KOICAI 
PubUcation No. 2003-029969. 

A 10-bit address is assigned to each of memory positions indicating memory areas 
in the module memory section 2, The module memory section 2 specifies a module by 
specifying the address of the module, i.e., the address of the top memory position (or a 

2 0 given part in the module, such as the end) at which the module is stored. 

As shown in FIG 8, every 16 bits of the memory area of the module address 
memory section 3 constitutes one page. A page address (page position) is assigned to that 
page. The individual pages of the module address memory section 3 are ordered firom a 
higher page to a lower page. The 16 bits that constitutes each page are likewise ordered 

2 5 from a higher significant bit to a lower one. 

Each page in the module address memory section 3 whose data structure is 
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exemplified in FIG 8 stores the address of each module stored in the module memory 
section 2 or a value indicating a jump distaace (offset value) in case of performing 
branching, and six bits of a control bit. In the example shown in FIG 7, the address of a 
module or an offset value occupies the lower ten bits of each page. The control bit occupies 
5 the upper six bits. 

The control bit consists of two bits indicating, for example, whether or not to allow 
the circuit control section 4 to perform a branch process (hereinafter called "branch control 
bit") and four bits indicating a branch condition in case of performing a branch process 
(hereinafter called "branch condition definition control bit"). 

When the branch control bit takes a predetermined value (e.g., a binary value of 
"10") and a condition specified by the branch condition definition control bit included in the 
same page as the branch control bit is fulfilled, the branch control bit instructs the circuit 
control section 4 to jump by the offset value stored in the page with the page address of the 
page as a start poiut. That is, in that case, the circuit control section 4 reads data stored on a 
page having the page address that is equivalent to the sum of the page address of the start 
page and the offset value stored on that page (i.e., data stored on the page to be jumped). 

When the branch control bit takes a value other than the predetermined value (e.g., 
a binary value of "00" or "01 "), on the other hand, the branch control bit instructs the circuit 
control section 4 to read a module specified by the address included in the same page as the 
branch control bit, from the module memory section 2. The branch control bit also iastructs 
the circuit control section 4 to reconfigure the programmable logic circuit 1 as indicated by 
the read module. Further, the branch control bit instructs the circuit control section 4 to 
read data stored on a next page to that page (specifically, a page with a page address which 
is the page address of the page incremented by "1 "). 

When the branch condition definition control bit takes a binary value of "0000", for 
example, the branch condition definition control bit indicates "signal Cond(0) having a 
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value of "0"" as a condition for executing a jump (conditional jump). 

When the branch condition definition control bit takes a binary value of "0001 for 
example, the branch condition definition control bit indicates "signal Cond(l) having a 
value of "0"" as a condition for executing a conditional jump. 
5 When the branch condition definition control bit takes a binary value of "0010", for 

example, the branch condition definition control bit indicates "signal Cond(2) having a 
value of "0" " as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "0011", for 
example, the branch condition definition control bit indicates "signal Cond(3) having a 
1 0 value of "0" " as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "0100", for 
example, the branch condition definition control bit indicates "signal Cond(4) having a 
value of "0"" as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "1000", for 
1 5 example, the branch condition definition control bit indicates "signal Cond(0) having a 
value of "1 "" as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "1001 ", for 
example, the branch condition definition control bit indicates "signal Cond(l) having a 
value of "1 "" as a condition for executing a conditional jump. 
2 0 When the branch condition definition control bit takes a binary value of "1010", for 

example, the branch condition definition control bit indicates "signal Cond(2) having a 
value of "1"" as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "1011", for 
example, the branch condition definition control bit indicates "signal Cond(3) having a 
2 5 value of "1 "" as a condition for executing a conditional jump. 

When the branch condition definition control bit takes a binary value of "1100", for 
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example, the branch condition definition control bit iadicates "signal Cond(4) having a 

value of "1"" as a condition for executing a conditional jump. 

When flie branch condition definition control bit takes a binary value of "0111" or 

"1111 for example, the branch condition definition control bit indicates a condition such 
5 that "a jump is made (a jump is made unconditionally) as long as the branch control bit 

included on the same page as the branch condition definition control bit has the 

aforementioned predetermined value". 

The signals Cond(0) to Cond(4) are signals of a total of five bits to be supplied to 

the circuit control section 4 from the logic circuit BFBC which is executing a process of 
1 0 monitoring whether or not a condition is fulfilled, the logic circuit BQBC which is 

executing a process of holding the result of another process, or the output logic circuit 

BOBC which is executing a process of outputting the monitoring result. In what case the 

signals Cond(O) to Cond(4) are supplied from the logic circuit BFBC, the logic circuit 

BQBC or the output logic circuit BOBC is described in a module beforehand. Possible 
1 5 targets to be monitored on fulfilhnent of a condition include, for example, a condition for 

calling another process and a condition for returning to the original process from which 

another process has been called, besides the condition for executing a conditional jump. 
The circuit control section 4 is constituted by a controller including a processor, 

such as a CPU (Central Processing Unit), and a non-volatile memory, such as ROM (Read 
2 0 Only Memory) where a program to be executed by the processor is stored. Altematively, 

the controller constituting the circuit control section 4 may be comprised of an exclusive 

electronic circuit 

The circuit control section 4 executes, for example, a process as illustrated in FIG 9, 
When the circuit control section 4 is comprised of a processor, a non-volatile memory and 
25 so forth, the process shown in FIG 9 is carried out as the processor loads the program 
stored in, for example, the non-volatile memory and runs the program. 
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Specifically, when the circuit control section 4 starts an operation, the circuit control 
section 4 reads data stored on a page having the topmost page address in the module 
address memory section 3 (i.e., the control bit and the address of a module or the offset 
value) first (step SI in FIG. 9). 
5 Next, the circuit control section 4 discriminates whether a page from which the 

latest data is read fix)m the module address memory section 3 at step S5, step S7 or step S9 
to be discussed later is the last page or not, i.e., whether or not the page is a page given the 
lowest page address (step S2). When deciding that the page is the last one, the circuit 
control section 4 terminates the process. 

1 0 When deciding that the page is not the last one, the circuit control section 4 

discriminates which process, (a) reading of a module or (b) branching (conditional jump or 
unconditional jump), the control bit included in the latest data read from the module address 
memory section 3 indicates (step S3). 

When deciding that the control bit indicates the process (a), the circuit control 

1 5 section 4 reads a module, specified by an address included in the latest data read from the 
module address memory section 3, from the module memory section 2. Then, the circuit 
control section 4 reconfigures the progranomable logic circuit 1 in such a way as to take the 
logic configuration indicated by the module (step S4). At step S4, specifically, the circuit 
control section 4 generates, for example, the aforementioned control signals Configl, 

2 0 ConfigFi, ConfigFf, ConfigFo, ConfigQi, ConfigQo, ConfigO and ConfigL and sends the 
control signals to the programmable logic circuit 1 in order to reconfigure the 
programmable logic circuit 1. 

When the process at step S4 is finished, the circuit control section 4 reads data 
stored on a next page to the page from which the latest data has been read, from the module 

2 5 address memory section 3 (step S5). Then, the circuit control section 4 returns the process 
to step S2. 
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When deciding at step S3 that the control bit indicates the process (b), on the other 
hand, the circuit control section 4 discriminates which process, (c) unconditional jump or 
(d) conditional jump, the branch condition definition control bit included in the control bit 
indicates (step S6). At step S6, specifically, the circuit control section 4 discriminates 
5 whether the value of the branch condition definition control bit is "01 1 1 " or " 1 1 1 1 When 
the value of the branch condition definition control bit takes either value, the circuit control 
section 4 decides that an unconditional jump is instructed. When the value of the branch 
condition definition control bit takes a value other than the two values, the circuit control 
section 4 decides that a conditional jump is instructed. 

1 0 When deciding at step S6 that an unconditional jump is instructed, the circuit 

control section 4 jumps by the offset value included in the same page as the control bit (i.e., 
reads data stored at the page to be jumped) (step S7). Then, the circuit control section 4 
returns the process to step S2. 

When deciding at step S6 that a conditional jump is instructed, on the other hand, 

15 the circuit control section 4 acquires, for example, the signals Cond(O) to Cond(4) supplied 
from the programmable logic circuit 1 (step S8). Then, the circuit control section 4 
discriminates whether the branch condition indicated by the branch condition definition 
control bit is fulfilled or not, based on the values indicated by the acquired signals Cond(O) 
to Cond(4) (step S9). When deciding that the branch condition is not fulfilled, the circuit 

2 0 control section 4 reads data stored on a next page to the page from which the latest data has 
been read, from the module address memory section 3 (step SIO). Then, the circuit control 
section 4 returns the process to step S2. When deciding that the branch condition is 
fulfilled, on the other hand, the circuit control section 4 returns the process to step S7. 

The programmable logic circuit 1 performs arithmetic operations according to its 

2 5 own logic configuration of the time when a signal supplied to the input logic circuit BIBC 
from outside, by using that signal or the old operation result held in the logic circuit BQBC. 
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Then, the programmable logic circuit 1 holds a signal indicating the operation result in the 
logic circuit BQBC or outputs the signal fern the output logic circuit BOBC. 

Through the operation, the programmable logic circuit control apparatus can 
execute logic configuration of the progranamable logic circuit 1 in a predetermined order 
5 one after another. In addition, the programmable logic circuit control apparatus smoothly 
executes logic configuration in complicated procedures involA^g conditional branching 
and unconditional branching. 

The structure of the programmable logic circuit control apparatus is not limited to 
the one described above. 
1 0 For example, a single memory device may execute the functions of the module 

memory section 2 and the module address memory section 3. 

Data which is stored in the module address memory section 3 should not 
necessarily take the above-described data structure. For example, the number of bits 
constituting one page is arbitrary. The number of bits of the address of a module, the page 
1 5 address, the offset value, the branch control bit or the branch condition definition control bit, 
and the positions in each page in the module address memory section 3 are also arbitrary. 

The conditions for the circuit control section 4 to make a jump are not limited to 
those discussed above. For example, the condition of executing a jump should not 
necessarily be associated with the values of the signals Cond(O) to Cond(4). The condition 
2 0 may be associated with arbitrary information that is acquirable by the circuit control section 
4. 

The signal Cond may represent a value obtained as a result of performing a 
predetermined process, such as a logic operation, on the value of a signal which is 
generated a single node or at each of plural nodes of the programmable logic circuit 1 when 
25 at one timing or plural timings. In this case, the programmable logic circuit 1 should have a 
logic circuit which executes the logic operation or so. 
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The circuit control section 4 may execute not only a jump in the aforementioned 
mode (i.e., a relative jump), but also an absolute jump. la this case, for example, the branch 
control bit stored in the module address memory section 3 should express three kinds of 
instructions, for example, a relative jump, an absolute jxmip and no jump. When the branch 
5 control bit instructs the absolute jump, the circuit control section 4 should interpret that the 
address of a page to be jumped is stored on the page that includes the branch control bit, 
instead of an offset value. In this case, the page address of the page to be jumped is stored 
on the page that includes the branch control bit, instead of an offset value. 

The programmable logic circuit control apparatus may further have a memory 
1 0 having a memory area which serves as last-in-first-out (LIFO) stack. Then, the 

programmable logic circuit control apparatus may use the stack to manage page addresses 
of pages in the module address memory section 3 in the stack, and achieve call and return 
functions. The call and return functions can be accomplished by, for example, the 
following scheme. 

1 5 The control bit is so designed as to be able to include data instructing a calling 

process or data instructing a return process. A page to be jumped in a branch process stores 
the address of a module which is repeatedly used. The control bit of a page to be jumped 
includes data which instructs returning. At the time of calling a page to be jumped, the 
circuit control section 4 stores the page address of a next page to the page which is currentiy 

2 0 executed. Then, the circuit control section 4 loads data stored at a page to be jumped and 
reconfigures the programmable logic circuit 1. Next, the circuit control section 4 reads out 
a page address stored in the stack (the address of a next page to the page which has been 
executed before jumping), and jumps to a page indicated by the page address. 
This scheme can achieve the call and return functions. 

25 To cope with a case where a process to be executed by the programmable logic 

circuit 1 is processed not in synchronism with other devices or so or where the time needed 
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for the process is not constant, a module may define the logic configuration of the 
programmable logic ckcuit 1 in such a way as to cause the logic circuit BFBC to monitor 
the end of the processing by the programmable logic circuit 1, the logic circuit BQBC to 
hold the monitoring result, and the output logic circuit BOBC to supply data indicating the 
5 end of the process to the circuit control section 4. 

When a module defines a logic configuration in such a way as to cause the 
programmable logic circuit 1 to execute a process which is known beforehand to terminate 
by a predetermined number of clocks, the modide may define the logic configuration in 
such a way as to allow the progranamable logic circuit 1 to furfher function as a counter to 

1 0 count the number of clocks of the clock signal and a logic circuit which discriminates 

whether the nimiber of clocks counted by the counter has reached a predetermined number 
or not and supplies data indicating the end of the process to the circuit control section 4 
when deciding that the number of clocks has reached the predetermined number. 

The circuit control section 4, the module address memory section 3 and/or the 

1 5 module memory section 2 may be constructed by the progranamable logic circuit 1 . In this 
case, the programmable logic circuit control apparatus further includes a non-volatile 
memory device (e.g., ROM or so) which stores a module defining the logic configuration 
for allowing the programmable logic circuit 1 to function as, for example, the circuit control 
section 4, the module address memory section 3 and/or the module memory section 2. The 

2 0 programmable logic circuit 1 should have a control circuit or so which reads a module 
stored in the non-volatile memory device at a timing immediately after activation of the 
programmable logic circuit control apparatus and changes the logic configuration of the 
programmable logic circuit 1 as defined by the module. 

Although one embodiment of the invention has been described above, the 

2 5 programmable logic circuit control apparatus according to the invention can be realized by 
using an ordinary computer system, not an exclusive system. For example, as programs for 



wo 2005/064456 PCT/JP2004/019819 

26 

executing the operations of the module memory section 2, the module address memory 
section 3 and the circuit control section 4 are loaded from a medium (CD-ROM, MO or the 
like) where the programs are stored and installed in a computer connected to the 
programmable logic circuit 1, the computer functions as the programmable logic circuit 
5 control apparatus that executes the above-described processes. 

A method of providing a computer with the programs is not linaited. For example, 
programs may be uploaded to a BBS (Bulletin Board System) of a conamunication circuit, 
and distributed to the computer via the communication circuit. Alternatively, each program 
may be transmitted in a modulated wave which is a carrier wave modulated by a signal 

1 0 representing the program, and a unit which receives the modulated wave demodulates the 
modulated wave to restore the program. Then, the computer activates the program and 
executes the program in the same way as executing other application programs under the 
control of an OS (Operating System). This allows the computer to function as the 
programmable logic circuit control apparatus that executes the above-described processes, 

1 5 When the OS is in charge of a part of a process, or the OS constitutes a part of a 

single structural element of the invention, a recording medium may store a program 
excluding that part In this case, a program for executing individual functions or steps that a 
computer performs should be stored in the recording medium according to the invention. 
Various embodiments and changes may be made thereunto without departing from 

2 0 the broad spirit and scope of the invention. The above-described embodiment is intended to 
illustrate the present invention, not to limit the scope of the present invention. The scope of 
tiie present invention is shown by the attached claims rather than the embodiment. Various 
modifications made withia the meaning of an equivalent of the claims of the invention and 
within the claims are to be regarded to be in the scope of the present invention. 

2 5 This application is based on Japanese Patent Application No. 2003-433210 filed on 

December 26, 2003 and including specification, claims, drawings and summary. The 
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disclosure of the above Japanese Patent AppKcation is incorporated herein by reference in 
its entirety. 
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CLAIMS 

1. Aprograminable logic circuit control apparatus comprising: 
a controller (4) which supplies a control signal to an external programmable logic 
circuit (1) having a function of changing a logic configuration in accordance with a 
5 supplied control signal; 

a module storage memory (2) which stores a plurality of modules each comprised 
of data defining a logic configuration of said programmable logic circuit (1); and 

a module usage order designation memory (3) which has a plurality of ordered 
memory positions, each of the memory positions storing data for designating an address of 
0 a memory position of said modxde storage memory (2) in which a module to be executed is 
stored or storing data for designating an address of another memory position of this module 
usage order designation memory (3), 

wherein said controller (4) acquires data stored at a memory position in said module 
usage order designation memory (3), 
5 determines which of an address of the memory position storing the module and an 

address of the another memory position is designated by acquired data, 

when having determined that said acquired data designates an address of the 
module, acquires said module stored in a memory position indicated by said address from 
said module storage memory (2), generates a control signal which controls said 
0 prograjoamable logic circuit (1) to take a logic configuration defined by said module and 
supplies generated control signal to said programmable logic circuit (1), and 

when having determined that said acquired data designates another memory 
position, acquires data stored at said another memory position from said module usage 
order designation memory (3). 
5 2. The programmable logic circuit control apparatus according to claim 1, wherein 

when data stored at a memory position in said module usage order designation memory (3) 
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designates another memory position in said module usage order designation memory (3), 
said data includes condition definition data designating a condition to start a process of 
acquiring data stored at said another memory position, and 

said controller (4) determines whether a condition designated by said condition 
5 definition data included in said acquired data is fulfilled or not when having determined that 
said acquired data designates another memory position, 

acquires data stored at said another memory position of said module usage order 
designation memory (3) when having detenxiined said condition is fulfilled, and 

aborts acquisition of data at said another memory position when having detemmbed 
1 0 that said condition is not fulfilled. 

3. The programmable logic circuit control apparatus according to claim 2, wherein 
said condition designated by said condition definition data relates to a value given by a 
signal which is generated at a predetermined node of said progranmiable logic circuit (1), 
and 

1 5 when having determined that data stored at a memory position in said module usage 

order designation memory (3) designates another memory position, said controller (4) 
acquires said signal from said node of said programmable logic circuit (1), and determines 
based on said value given by said acquired signal whether that condition which is 
designated by said condition definition data included in said data acquired from said 

2 0 module usage order designation memory (3) is fulfilled or not 

4. The programmable logic circuit control apparatus according to claim 1, wherein 
data stored at a memory position in said module usage order designation memory (3) 
includes identification data for identifying which one of an address of the memory position 
storing a module and an address of another memory position is designated by said stored 

25 data, 

said controller (4) determines based on said identification data included in said data 
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acquired from said module usage order designation memory (3) which of an address of the 
memory position storing the module and an address of the another memory position is 
designated. 

5. Aprogranunable logic circuit control apparatus that acquires a module 
5 comprised of data defining a logic configuration of an external prograromable logic circuit 
(1) having a function of changing a logic configuration in accordance with a supplied 
control signal from a module storage memory (2) which stores a plurality of modules, 
generates a control signal which controls said programmable logic circuit (1) to take a logic 
configuration defined by said acquired module and supplies generated control signal to said 
1 0 programmable logic circuit (1), and that comprises: 

means which acquires data stored at a memory position in an extemal module usage 
order designation memory (3) which has a plurality of ordered memory positions, each of 
the memory position storing data for designating an address of a memory position of said 
module storage memory (2) in which a module to be executed is stored or storing data for 
1 5 designating an address of another memory position of this module usage ord^ designation 
memory (3), from said module usage order designation memory (3); 

means which determines which of an address of the memory position storing the 
module and an address of the another memory position is designated by acquired data; 

means which, when it is determined that said acquired data designates an address of 
20 the module, acquires said module stored in a memory position indicated by said address 
from said module storage memory (2), and changes said logic configuration of said 
programmable logic circuit (1) so that said programmable logic circuit (1) takes a logic 
configuration defined by said module; and 

means which, when it is determined that said acquired data designates another 
2 5 memory position, acquires data stored at said another memory position from said module 
usage order designation memory (3). 
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6. A programmable logic circuit control method which supplies a control signal to 
an external programmable logic circuit (1) having a function of changing a logic 
configuration in accordance with said supplied control signal, and comprises the steps of: 

storing a plurality of modules each comprised of data defining a logic configuration 
5 of said programmable logic circuit (1); 

storing data for designating an address of a memory position storing a module or an 
address of another memory position at each of a plurality of ordered memory positions; 
acquiring data stored at each of said memory positions; 

determining which of an address of the memory position storing the module and an 
1 0 address of the another memory position is designated by the acquired data; 

whm it is determined that said acquired data designates an address of a memory 
position storing a module, acquiring said module stored m the memory position indicated 
by said address, generating a control signal which controls said programmable logic circuit 
(1) to take a logic configuration defined by said module and supplying said control signal to 
1 5 said programmable logic circuit (1); and 

when it is determined that said acquired data designates an address of another 
memory position, acquiring data stored at said another memory position. 

7. A programmable logic circuit control method that acquires a module comprised 
of data defining a logic configuration of an external programmable logic circuit (1) having a 

2 0 function of changing a logic configuration in accordance with a supplied control signal 

firom a module storage memory (2) which stores a plurality of modules, generates a control 
signal which controls said programmable logic circuit (1) to take a logic configuration 
defined by said acquired module and supplies said control signal to said programmable 
logic circuit (1), and that comprises the steps of: 

2 5 acquiring data stored at a memory position in an extemal module usage order 

designation memory (3) which has a plurality of ordered memory positions, each of the 
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memory positions storing data for designating an address of a memory position of said 
module storage memory (2) in which a module to be executed is stored or storing data for 
designating an address of another memory position of this module usage order designation 
memory (3); 

5 determining which of an address of the memory position storing the module and an 

address of the another memory position is designated by the acquired data; 

when it is determined that said acquired data designates an address of a memory 
position storing a module, acquiring said module stored in the memory position indicated 
by said address from said module storage memory (2), and changing said logic 
1 0 configuration of said programmable logic circuit (1) so that said programmable logic circuit 
(1) takes a logic configuration defined by said module; and 

when it is determined that said acquired data designates another memory position, 
acquiring data stored at said another memory position from said module usage order 
designation memory (3). 
15 8. Aprogram for allowing a computer to function as: 

a controller (4) which supplies a control signal to an external programmable logic 
circuit (1) having a function of changing a logic configuration in accordance with said 
supplied control signal; 

a module storage memory (2) which stores a plurality of modules each comprised 
20 of data defining a logic configuration of said programmable logic circuit (1); and 

a module usage order designation memory (3) which has a plurality of ordered 
memory positions, each of the memory positions storing data for designating an address of 
a memory position of said module storage memory (2) in which a module to be executed is 
stored or storing data for designating an address of another memory position of the module 
2 5 usage order designation memory (3), 

wherein said controller (4) acquires data stored at a memory position in said module 
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usage order designation memory (3), 

determines which of an address of the memory position storing the module and an 
address of the another memory position is designated by the acquired data, 

when having determined that said acquired data designates an address of a module, 
5 acquires said module stored in a memory position indicated by said address from said 
module storage memory (2), generates a control signal which controls said programmable 
logic circuit (1) to take a logic configuration defined by said module and supplies the 
generated control signal to said programmable logic circuit (1), and 

when having determined that said acquired data designates anoth^ memory 
1 0 position, acquires data stored at said another memory position from said module usage 
order designation memory (3). 

9. A program for allowing a computer to function as a programmable logic circuit 
control apparatus that acquires a module comprised of data defining a logic configuration of 
an external progranamable logic circuit (1) having a function of changing a logic 
1 5 configuration in accordance with a supplied control signal from a module storage memory 
(2) which stores a plurality of modules, generates a control signal which controls said 
programmable logic circuit (1) to take a logic configuration defined by said acquired 
module and supplies generated control signal to said progranomable logic circuit (1), and for 
further allowing said computer to perform the functions of: 
2 0 acquiring data stored at a memory position in an extemal module usage order 

designation memory (3) which has a plurality of ordered memory positions, each of the 
memory positions storing data for designating an address of a memory position of said 
module storage memory (2) in which a module to be executed is stored or storing data for 
another memory position of this module usage order designation memory (3); 
2 5 determining which of an address of the memory position storing the module and an 

address of the another memory position is designated by acquired data; 
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when it is deteramied that said acquired data designates an address of a module, 
acquiring said module stored isi a memory position indicated by said address from said 
module storage memory (2), and changing said logic configuration of said programmable 
logic circuit (1) so that said programmable logic circuit (1) takes a logic configuration 
5 defined by said module; and 

when it is determined that said acquired data designates another memory position, 
acquiring data stored at said another memory position from said module usage order 
designation memory (3). 
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